package demo9_huffmantree;


import java.util.ArrayList;
import java.util.Collections;
import java.util.List;

public class TestHuffmanTree {
    public static void main(String[] args) {
        int[] arr = new int[]{3, 5, 7, 8, 11, 14, 23, 29};
        Node node = createHuffmanTree(arr);
        node.frontShow();
    }

    //创建赫夫曼树
    public static Node createHuffmanTree(int[] arr) {
        //先使用数组中的所有的元素创建若干个二叉树  (只有一个节点)
        List<Node> nodes = new ArrayList<>();
        for (int value : arr) {
            nodes.add(new Node(value));
        }
        //循环处理
        while (nodes.size() > 1) {
            //排序
            Collections.sort(nodes);
            //取出权值最小的两个二叉树
            //取出权值最小的二叉树
            Node left = nodes.get(0);
            //取出权值次小的二叉树
            Node right = nodes.get(1);
            //创建一颗新的二叉树
            Node parent = new Node(left.value + right.value);
            parent.left = left;
            parent.right = right;
            //把取出来的两个二叉树移除
            nodes.remove(left);
            nodes.remove(right);
            //放入原来的二叉树聚合中
            nodes.add(parent);
        }
        return nodes.get(0);
    }
}
